import java.util.*;//导入万能类 当然也不是很万能
public class Test {
    static List<Integer> oList = new LinkedList<>();//需要用到的集合
    public static void main(String[] args) {
        //标准输入 一个n
        Scanner sc  = new Scanner(System.in);
        int n = sc.nextInt();

        if (isPrime(n)){
            //如果输入数为质数，那么打印-1。因为我们的n应该是质数的倍数，且必须至少为2倍（题目中说了选择一个小于x的素数p，所以至少是2倍）。
            System.out.println("-1");
        }else {
            oList = prime(n);
            //对其质因数分解,并用集合装好
            int minstart = Integer.MAX_VALUE;//定义所求的最小开始的a0,赋值为Integer最大值，为了后面获取最小值
            for (int i = 0; i < oList.size(); i++) {
                //遍历质因数集合
                int last_left = n-oList.get(i);
                //下面对第一次操作后可能的数组遍历
                for (int j = last_left+1; j <= n ; j++) {
                    //这里的范围为什么是从last_left+1到n
                    //假设第二次操作选择的是oList.get(i)作为质数，那么第二次操作前的数(a1)不会小于n-oList.get(i)
                    //上次操作前的数字（a1）必然在左边界加1和n之间。（为什么是n？因为n可能本身就是某个质数的倍数，然后这次操作又选了该质数，则n不变）
                    if (isPrime(j)){
                        continue;
                        //跟上面一样，不可能是质数。
                    }
                    List<Integer> temp = prime(j);//继续对上个数进行质因数分解
                    int max = Collections.max(temp);
                    //找出最大的质因数作为第一次操作选择的质数，这样能使起始数字(即a0)尽可能小
                    minstart = Math.min(j-max+1,minstart);//更新维护最小数字

                }
            }
            if (minstart==Integer.MAX_VALUE){
                System.out.println("-1");
            }else {
                System.out.println(minstart);
            }
        }

    }
    //质数的判断
    private static boolean isPrime(int n){
        if (n<2)return false;
        if (n==2||n==3)return true;
        if (n%6!=1&&n%6!=5)return false;
        for (int i = 5; i*i<= n ; i+=6) {
            if (n%i==0||n%(i+2)==0){
                return false;
            }
        }
        return true;
    }
    //对n进行质因数分解
    private static List<Integer> prime(int n){
        List<Integer> ans  = new LinkedList<>();
        for(int i = 2; i <= n/i ; i++){//判断条件用n/i，以防i*i<=n发生溢出
            int a = 0;//每次循环都要清零
            while(n % i == 0){
                n /= i;
                a++;
            }
            if(a > 0)
                ans.add(i);
        }
        //若该数是质数，那么应该将自身(n)也加入
        if(n > 1) ans.add(n);
        return ans;
    }
}